package com.fc.test.controller.admin;

import com.fc.test.common.base.Constants;
import com.fc.test.model.auto.TSysDictData;
import com.fc.test.util.ExcelUtil;
import com.zhengqing.demo.utils.TableToWordUtil;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import com.github.pagehelper.PageInfo;
import com.fc.test.common.base.BaseController;
import com.fc.test.common.domain.AjaxResult;
import com.fc.test.model.auto.SysPosition;
import com.fc.test.model.custom.TableSplitResult;
import com.fc.test.model.custom.Tablepar;
import com.fc.test.model.custom.TitleVo;
import com.fc.test.service.SysPositionService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;

import javax.servlet.http.HttpServletResponse;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;

@Controller
@RequestMapping("/SysPositionController")
@Api(value = "岗位表")
public class SysPositionController extends BaseController {

    private String prefix = "admin/sysPosition";
    @Autowired
    private SysPositionService sysPositionService;

    /**
     * list展示
     */
    @ApiOperation(value = "分页跳转", notes = "分页跳转")
    @GetMapping("/view")
    @RequiresPermissions("gen:sysPosition:view")
    public String view(ModelMap model) {
        String str = "单词";
        setTitle(model, new TitleVo("列表", str + "管理", true, "欢迎进入" + str + "页面", true, false));
        return prefix + "/list";
    }

    /**
     * 分页集合
     */
    //@Log(title = "岗位表集合查询", action = "111")
    @ApiOperation(value = "分页查询", notes = "分页查询")
    @PostMapping("/list")
    @RequiresPermissions("gen:sysPosition:list")
    @ResponseBody
    public Object list(Tablepar tablepar, String searchText) {
        PageInfo<SysPosition> page = sysPositionService.list(tablepar, searchText);
        TableSplitResult<SysPosition> result = new TableSplitResult<SysPosition>(page.getPageNum(), page.getTotal(), page.getList());
        return result;
    }

    /**
     * 新增跳转
     */
    @ApiOperation(value = "新增跳转", notes = "新增跳转")
    @GetMapping("/add")
    public String add(ModelMap modelMap) {
        return prefix + "/add";
    }

    /**
     * 新增
     */
    //@Log(title = "岗位表新增", action = "111")
    @ApiOperation(value = "新增", notes = "新增")
    @PostMapping("add")
    @RequiresPermissions("gen:sysPosition:add")
    @ResponseBody
    public AjaxResult add(SysPosition sysPosition) {
        int b = sysPositionService.insertSelective(sysPosition);
        if (b > 0) {
            return success();
        } else {
            return error();
        }
    }



    /**
     * excel导出
     */
    @GetMapping("/excel")
    public void excel(HttpServletResponse response) throws Exception {

        List<SysPosition> positions = sysPositionService.list();
        Collections.shuffle(positions);
        int i = 1;
        for (SysPosition position : positions){
            position.setOrderNum(i);
            i++;
        }
        String str = "单词";
        String path = Constants.FILE_PATH + "\\" + str + "-ok的" + ".doc";
        TableToWordUtil.toWord(positions,path,str);
        return;
//        ExcelUtil.writeExcel(response, positions, str, str, new SysPosition());
    }


    /**
     * 删除用户
     *
     * @param ids
     * @return
     */
    //@Log(title = "岗位表删除", action = "111")
    @ApiOperation(value = "删除", notes = "删除")
    @PostMapping("/remove")
    @RequiresPermissions("gen:sysPosition:remove")
    @ResponseBody
    public AjaxResult remove(String ids) {
        int b = sysPositionService.deleteByPrimaryKey(ids);
        if (b > 0) {
            return success();
        } else {
            return error();
        }
    }

    /**
     * 检查用户
     *
     * @param tsysUser
     * @return
     */
    @ApiOperation(value = "检查Name唯一", notes = "检查Name唯一")
    @PostMapping("/checkNameUnique")
    @ResponseBody
    public int checkNameUnique(SysPosition sysPosition) {
        int b = sysPositionService.checkNameUnique(sysPosition);
        if (b > 0) {
            return 1;
        } else {
            return 0;
        }
    }


    /**
     * 修改跳转
     *
     * @param id
     * @param mmap
     * @return
     */
    @ApiOperation(value = "修改跳转", notes = "修改跳转")
    @GetMapping("/edit/{id}")
    public String edit(@PathVariable("id") String id, ModelMap mmap) {
        mmap.put("SysPosition", sysPositionService.selectByPrimaryKey(id));

        return prefix + "/edit";
    }

    /**
     * 修改保存
     */
    //@Log(title = "岗位表修改", action = "111")
    @ApiOperation(value = "修改保存", notes = "修改保存")
    @RequiresPermissions("gen:sysPosition:edit")
    @PostMapping("/edit")
    @ResponseBody
    public AjaxResult editSave(SysPosition record) {
        return toAjax(sysPositionService.updateByPrimaryKeySelective(record));
    }


    /**
     * 根据主键查询
     *
     * @param id
     * @param mmap
     * @return
     */
    @PostMapping("/get/{id}")
    @ApiOperation(value = "根据id查询唯一", notes = "根据id查询唯一")
    public SysPosition edit(@PathVariable("id") String id) {
        return sysPositionService.selectByPrimaryKey(id);
    }


}
